草庐IT

java - 安全的 JDBC 连接

全部标签

mongodb - 如何将本地Mongo数据库连接到docker

我正在从事golang项目,最近我阅读了有关docker的信息,并尝试在我的应用程序中使用docker。我正在使用mongoDB作为数据库。现在的问题是,我正在创建Dockerfile来安装所有包并编译和运行go项目。我在本地运行mongo数据,如果我在没有docker的情况下运行go程序,它会给我输出,但是如果我在同一个项目中使用docker(只是安装依赖项并运行这个项目),它编译成功但没有给出任何输出,有错误::CreateSession:noreachableservers我的Dockerfile::#StartfromaDebianimagewiththelatestversi

postgresql - 微服务使 postgres 连接倍增

我有一个通过golang编写的服务,它作为消费者工作,它从kafka的队列中获取数据并将其存储在PostgreSQL数据库中。在执行某些请求时,golang开始增加PG连接,然后超过它们的限制。我不知道为什么,请帮我解决这个问题。这是代码:funcSaveMessageStatus(msgmodels.Message)error{db:=GetPostgreInstance()//Get*sql.DBinstance//Проверяеместьлизаписиrows,err:=db.Query(`select*from"tNotifStatus"where"Notification

http - 如果内容长度错误,Chrome 会关闭 tcp 连接吗?

我对Web服务器对httpkeep-aliveheader的操作很感兴趣。所以我在httpserver的基础上搭建了一个简单的httpserver。服务器除了使用简单的htmlhttp正文响应客户端之外什么都不做。服务器代码在这里:packagemainimport("fmt""net""os")funcmain(){l,err:=net.Listen("tcp","localhost:9765")iferr!=nil{fmt.Println("Errorlistening:",err.Error())os.Exit(1)}deferl.Close()for{conn,err:=l.A

go - 由于 slice 中的项目数正在变化,如何安全地从 slice 中删除项目

在我遍历用户slice后,我需要根据某些条件从slice中删除一些用户。我将多次遍历此用户slice,慢慢删除一些元素。我从其他语言了解到,在循环时从集合中删除项目是不安全的。所以我正在做的是将我想要删除的元素存储在maptoMutate中。原始循环完成后,我会继续尝试从slice中删除元素。toMutate:=make(map[int]User,100)foridx,u:=rangec.users{ifsomeCondition{toMutate[idx]=u}}然后我调用此函数从用户的slice中删除项目。foridx,u:=rangetoMutate{c.users=append

go - 是否可以断言通过像 Java Mockito 一样在 Go 中进行 spy 事件来调用真正的方法?

我正在寻找断言我的测试中涵盖了一个语句。例如,假设从测试开始调用methodA(),它引用了methodB()。我想断言在从测试中执行methodA()时会调用methodB()。在下面的代码中,我如何在Go测试中断言svc.AddCheck()在执行svc.OnStartup()时被调用?func(svc*Servjice)OnStartup()error{iferr:=svc.AddCheck("cache");err!=nil{returnerr}returnnil} 最佳答案 Isitpossibletoassertthat

unit-testing - 如何在不创建实际网络连接的情况下测试依赖于 net.Conn 的代码?

如果我有适用于net.Conn的代码,我如何在不实际创建与本地主机的网络连接的情况下为其编写测试?我在网上没有看到这个问题的解决方案;人们似乎要么忽略它(不进行测试),要么编写无法并行运行的测试(即使用实际的网络连接,这会耗尽端口),要么使用io.Pipe。不过,net.Conn定义了SetReadDeadline、SetWriteDeadline;而io.Pipe没有。net.Pipe也没有,尽管表面上声称要实现该接口(interface),但它只是通过以下方式实现:func(p*pipe)SetDeadline(ttime.Time)error{return&OpError{Op:

go - 使用go-sql-driver时如何区分连接错误和其他错误

funcmainloop(db*sql.DB){typepushTaskstruct{TaskIdstringUristring}stmt,err:=db.Prepare("INSERTINTOErrPushCache(TaskId,Uri)VALUES(?,?)")iferr!=nil{log.Fatal("db.PrepareFailed",err)}var(mysqlOkbool=truetaskpushTask)for{task.TaskId=RandStringRunes(8)task.Uri=RandStringRunes(16)res,err:=stmt.Exec(tas

java - 从一个 ORM 迁移到另一个

这是我的问题。我现在正在使用Play2Framework,它为我提供了Ebean作为我的默认ORM产品。我对Java比较了解,决定用Java写一个网站,但我也想学习Go,最终把我网站的后端代码改成Go(Go的框架Revel)。我知道我的数据仍会存在,但我将不得不使用不同的ORM产品来重写所有模型。即使我保持完全相同的数据库结构,这会导致问题吗? 最佳答案 这取决于您对“问题”的定义。ORM框架提供了将数据库信息(关系数据)映射到OOP对象的工具。ORM框架之间存在差异,例如它们支持的DBMS、将表/列名映射到类/字段时的默认命名规则

multithreading - App Engine Channel API 的线程安全/原子性

当我尝试使用GoogleAppEngine的ChannelAPI从两个或多个goroutines和/或任务队列发送消息时会发生什么?例如gochannel.Send(context,clientID,"Hello")gochannel.Send(context,clientID,"World")我知道在GAEGo中,所有goroutines都被多路复用到一个线程上。然而,这仍然允许在I/O期间进行抢占,并且channel发送可能符合I/O的条件。GAE开发服务器似乎序列化了所有请求,所以我没有看到任何channel发送重叠。生产服务器似乎允许一些请求并发,但channel发送看起来是原

database - go database/sql - 奇怪的连接和事务行为

使用Go和使用database/sql的数据库驱动程序的实现,我似乎遇到的交易行为似乎是每次交易后都需要关闭连接。如果我不这样做,数据库将耗尽连接,并且我会收到以下错误:"BeginTransactionfailed.Error=Error1040:Toomanyconnections".Thishappensafter101commits.我尝试使用来自github的两个不同驱动程序-lib/pq和go-sql-driver/mysql,结果相同。这种行为对我来说很奇怪。这是预料之中的,还是我做错了什么?根据要求,代码如下:packagemainimport("database/sq